# Основы VerirogHDL/SystemVerilog (синтез и моделирование)

- Часть lab4\_1
- □ На языке Verilog опишите устройство, включающее:
  - ✓ счетчик-делитель, обеспечивает счет по модулю 25 000 000 и формирование синхронного сигнала переноса (активный уровень сигнала 1, длительность один такт тактовой частоты) по достижению счетчиком значения 25 000 000-1.
  - Двоичный, 4-разрядный, счетчик, алгоритм работы, которого задан приведенной ниже таблицей.

| Asset<br>PB[0] |   |   | Load<br>sw[5] |   | din<br>sw[3:0] | q                                                                    |
|----------------|---|---|---------------|---|----------------|----------------------------------------------------------------------|
| 0              | х | х | х             | х | х              | Асинхронная установка (старший разряд счетчика =1, все остальные =0) |
| 1              | 0 | х | х             | х | х              | Хранение                                                             |
| 1              | 1 | 0 | х             | х | х              | Синхронный сброс счетчика в 0                                        |
| 1              | 1 | 1 | 0             | х | din            | Запись din                                                           |
| 1              | 1 | 1 | 1             | 1 | х              | Счет +                                                               |
| 1              | 1 | 1 | 1             | О | х              | Счет -                                                               |

- Часть lab4\_1
- □ Входы
  - ✓ СІк тактовая частота 25МГц
  - ✓ переключатели sw[7:0]
  - ✓ Кнопка РВ[0]
- □ Выходы (выходы двоичного 4-разрядного счетчика)
  - ✓ светодиоды led[3:0]
- Назначить выводы СБИС используя атрибуты
- □ Имя проекта lab4\_1. Имя модуля верхнего уровня lab4\_1.

- Часть lab4\_2
- На языке Verilog описать представленную ниже схему



- ✓ cnt счетчик-делитель: коэффициент деления задается константой; выход сигнал переноса
- ✓ srg сдвигающий регистр;
- ✓ Входы:
  - Сlk тактовый (25 МГц), sw[7..0] данные загружаемые в сдвигающий регистр, key[0] сигнал синхронной загрузки данных в сдвигающий регистр
- ✓ Выход led[7..0] содержимое сдвигающего регистра
- □ Назначить выводы СБИС используя атрибуты
- □ Имя проекта lab4\_2. Имя модуля верхнего уровня –lab4\_2.

- □ Часть lab4\_3
- На языке Verilog опишите 2-10 счетчик, содержащий 2 тетрады (счет десятков, счет единиц).
  - ✓ Счетчики десятков и единиц соединить каскадно.
  - ✓ Счетчики описать в отдельных процедурных блоках.
  - ✓ В отдельном процедурном блоке описать счетчик-делитель на 25 000 000, формирующий сигнал разрешения работы для счетчика десятков и счетчика единиц.
  - ✓ Выходы
    - счетчика десятков вывести на led[7:4],
    - счетчика единиц на led[3:0].
  - ✓ Предусмотреть сигнал сброса всех счетчиков, включая счетчик делитель, кнопка РВ[1]
- Назначить выводы СБИС используя атрибуты
- □ Имя проекта lab4\_3. Имя модуля верхнего уровня lab4\_3.

- Часть lab4\_4
- Описать на языке Verilog конечный автомат:
  - ✓ Тактовый сигнал clk
  - ✓ Входы sw[3:0] подать через два последовательно включенных триггера
  - Вход key[0] (сигнал асинхронного сброса) подать через два последовательно включенных триггера
- □ Посмотреть синтезированный пакетом Q схему и блок схему автомата (State Machine Viewer)
- □ Осуществить функциональное моделирование
- Назначить выводы СБИС используя атрибуты
- ☐ Имя проекта lab4\_4. Имя модуля верхнего уровня lab4\_4.



